package com.quectel.core.module.device.service;


import com.quectel.core.module.device.dto.DeviceCommandTemplateDto;

import java.util.List;
import java.util.Map;

/**
 * @author caolu
 * @email louis.cao@quectel.com
 * @date 2021-05-24 12:42:22
 */
public interface DeviceCommandTemplateService {

    DeviceCommandTemplateDto selectByByCode(String commandCode);

    /**
     * 查询列表
     *
     * @param params
     * @return
     */
    List<DeviceCommandTemplateDto> queryList(Map<String, Object> params);

    /**
     * 查询数量
     *
     * @param params
     * @return
     */
    int queryTotal(Map<String, Object> params);

    /**
     * 存入一条记录
     *
     * @param dto
     * @return 存入数据的id
     */
    Long save(DeviceCommandTemplateDto dto);

    /**
     * 根据id更新一条记录
     *
     * @param dto
     */
    void updateById(DeviceCommandTemplateDto dto);

    /**
     * 根据id强制更新某些字段 解决无法null值无法更新的问题<br/>
     * setParams.put("code",null);
     * setParams.put("create_time",new Date());
     * 以上两句会翻译成 update table set code=null,create_time=time where id=xxx
     *
     * @param setParams key value
     * @param id        更新数据的id
     */
    void forceUpdateColumnById(Map<String, Object> setParams, Long id);

    /**
     * 根据id查询一条记录
     *
     * @param id
     * @return
     */
    DeviceCommandTemplateDto selectById(Long id);

    /**
     * 根据id删除一条记录
     *
     * @param id
     */
    void deleteById(Long id);

    /**
     * 批量删除
     *
     * @param ids
     */
    void deleteBatch(Long[] ids);


}
